package com.itheima.dao;

import com.github.pagehelper.Page;
import com.itheima.pojo.Setmeal;
import org.apache.ibatis.annotations.Param;

import java.util.List;
import java.util.Map;

/**
 * 套餐持久层
 * @author ：zengjie
 * @date ：2020/11/10
 */
public interface SetmealDao {
    /**
     * 往套餐和检查组中间表插入数据
     */
    void setSetmealAndCheckGroup(@Param("setmealId") Integer setmealId,@Param("checkgroupId") Integer checkgroupId);

    /**
     * 新增套餐
     * @param setmeal
     */
    void add(Setmeal setmeal);

    /**
     * 分页查询
     * @param queryString
     * @return
     */
    Page<Setmeal> selectByCondition(String queryString);

    /**
     * 根据套餐id查询套餐信息
     * @param setmealId
     * @return
     */
    Setmeal findById(Integer setmealId);

    /**
     * 根据套餐id查询所有关联的检查组id
     * @param setmealId
     * @return
     */
    List<Integer> findGroupIdsBySetmealId(Integer setmealId);

    /**
     * 更新套餐信息
     * @param setmeal
     */
    void edit(Setmeal setmeal);

    /**
     * 删除需要更新的套餐所有关联的检查组关系
     * @param id
     */
    void deleteRsBySetmealId(Integer id);


    /**
     * 删除套餐
     * @param setmealId
     */
    void deleteById(Integer setmealId);

    /**
     * 根据套餐id查询是否存在关联的检查组
     * @param setmealId
     * @return
     */
    int findCountBySetmealId(Integer setmealId);

    /**
     * 查询套餐列表数据
     * @return
     */
    List<Setmeal> findAll();
    /**
     * 套餐数据饼图占比
     */
    List<Map> getSetmealReport();
}
